/*
 * @Author: 宋绍华
 * @Date: 2021-10-09 10:48:28
 * @LastEditTime: 2021-10-11 17:17:30
 * @LastEditors: 宋绍华
 * @Description:
 * @FilePath: \docguide\vue.config.js
 */
const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer')

module.exports = {
  // 项目部署的基础路径
  publicPath: '/',
  // 将构建好的文件输出到哪里（或者说将编译的文件）
  outputDir: 'dist',
  // 放置静态资源的地方 (js/css/img/font/...)
  assetsDir: '',
  // 用于多页配置，默认是 undefined
  // 是否在保存的时候使用 `eslint-loader` 进行检查。
  // 有效的值：`ture` | `false` | `"error"`
  // 当设置为 `"error"` 时，检查出的错误会触发编译失败。
  lintOnSave: true,
  // 使用带有浏览器内编译器的完整构建版本
  // 查阅 https://cn.vuejs.org/v2/guide/installation.html#运行时-编译器-vs-只包含运行时
  runtimeCompiler: false,
  // babel-loader 默认会跳过 node_modules 依赖。
  // 通过这个选项可以显式转译一个依赖。
  transpileDependencies: [
    /* string or regex */
  ],
  // 是否为生产环境构建生成 source map？
  productionSourceMap: false,
  // 调整内部的 webpack 配置。
  // 查阅 https://github.com/vuejs/vue-docs-zh-cn/blob/master/vue-cli/webpack.md
  // chainWebpack: () => {},
  configureWebpack: (config) => {
    if (process.env.NODE_ENV === 'production') {
      // 为生产环境修改配置
      // 去除console
      // if (config.optimization.minimizer[0].options.terserOptions?.compress?.drop_console) {
      //   config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
      // }

      if (process.env.APP_NODE_ENV === 'analysis') {
        // 分析打包依赖
        config.plugins.push(new BundleAnalyzerPlugin())
      }
    } else {
      // 为开发环境修改配置
    }
  },
  // CSS 相关选项
  css: {
    // 将组件内的 CSS 提取到一个单独的 CSS 文件 (只用在生产环境中)
    // 也可以是一个传递给 `extract-text-webpack-plugin` 的选项对象
    extract: true,

    // 是否开启 CSS source map？
    sourceMap: false,

    // 为预处理器的 loader 传递自定义选项。比如传递给
    // sass-loader 时，使用 `{ sass: { ... } }`。
    loaderOptions: {}

    // 为所有的 CSS 及其预处理文件开启 CSS Modules。
    // 这个选项不会影响 `*.vue` 文件。
    // modules: false
  },

  // 在生产环境下为 Babel 和 TypeScript 使用 `thread-loader`
  // 在多核机器下会默认开启。
  parallel: require('os').cpus().length > 1,

  // PWA 插件的选项。
  // 查阅 https://github.com/vuejs/vue-cli/tree/dev/packages/@vue/cli-plugin-pwa
  pwa: {},

  // 配置 webpack-dev-server 行为。
  devServer: {
    // open: process.platform === 'darwin',
    // host: '0.0.0.0',
    // port: 8080,
    // https: false,
    // hotOnly: false,
    // // 查阅 https://github.com/vuejs/vue-docs-zh-cn/blob/master/vue-cli/cli-service.md#配置代理
    // proxy: {
    //   '/api': {
    //     target: 'http://localhost:8880',
    //     changeOrigin: true,
    //     secure: false,
    //     // ws: true,
    //     pathRewrite: {
    //       '^/api': '/static/mock' // 请求数据路径别名,这里是注意将static/mock放入public文件夹
    //     }
    //   }
    // },
    // before: (app) => {}
  },
  // 三方插件的选项
  pluginOptions: {
    // ...
  }
}
